Deploying an ASP.NET Core 8.0 Application

Starting from ASP.NET Core 8.0 Hosting, we support multiple domains and multiple ASP.NET Core 8.0 Applications in ASP.NET Core 8.0 hosting. In this article we will show you how to deploy your asp.net core 8.0 application to our cloud platform.

Precondition:

  • Enabled FTP Server in client panel;
  • Enabled Shell/SSH in client panel;
  • Installed FileZilla client or other FTP client on your local PC;
  • Your must have an asp.net core 8.0 project on your local PC.

1. Enable FTP Server in Client Panel

Please refer to Transferring Data via FTPS to enable FTP Server and transfer your files via Filezilla client.

2. Transfer your asp.net core 8.0 project files to cloud platform via FileZilla client

2.1 Create a new directory under /cloudclusters

We have already deployed an asp.net core 8.0 demo project under /cloudclusters/default_site. You can create a new directory under /cloudclusters for the new asp.net core 8.0 project.

# cd /cloudclusters/ && mkdir myproject

2.2 Transfer your asp.net core 8.0 project files into new folder

Then please follow up Transferring Data via FTPS to upload your asp.net core 8.0 project files into /cloudclusters/myproject.

3. Start up your asp.net core 8.0 project

As there have a demo project under /cloudclusters/default_site and the demo project is listening on 5200. You can let your asp.net core 8.0 project listening on 5300 or other port. To check the listening port for demo project:

# netstat –natpl

3.1 Make a start script for asp.net core 8.0 project

Under /cloudclusters/config/aspnet, you can copy a start script from startup.sh

# cd /cloudclusters/config/aspnet
# cp startup.sh myproject.sh

Then modify myproject.sh

#vim myproject.sh

You have to define the start .dll file and urls in the start script. The listening port is defined in urls.

3.2 Start asp.net core 8.0 project by supervisor

We are using supervisor to manage the asp.net core 8.0 applications. Under /cloudclusters/config/supervisor, copy a new file from demo.conf

# cd /cloudclusters/config/supervisor
# cp demo.conf myproject.conf

Modify myproject.conf

# vim myproject.conf

Update supervisor to make it working.

# supervisorctl update
# supervisorctl status

Check the listening port:

4. Update nginx to make the asp.net core 8.0 project accessable

We are using nginx as a web server to reverse proxy for the asp.net core 8.0 project. There have two methods to access your project. You can use path or your domain to access the asp.net core 8.0 project.

4.1 Using path to access the asp.net core 8.0 project with the default domain

If you do not have a domain then you can use any path to access the asp.net core 8.0 project with the default domain. Modify default.conf under /cloudclusters/config/nginx. There we use “/my” as path as example. You can use any path excepting “/”.

# cd  /cloudclusters/config/nginx
# vim default.conf

Example for default.conf

server {
    listen 80;
    server_name aspnetclusters-188*80-0.cloudclusters.net;

    location / {
        proxy_pass http://127.0.0.1:5200$request_uri;
        root /cloudclusters/default_site;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_buffering off;
    }

    location /my {
        proxy_pass http://127.0.0.1:5300$request_uri;
        root /cloudclusters/myproject;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_buffering off;
    }
}

Restart nginx.

# supervisorctl restart nginx

Access the the asp.net core 8.0 project with the default domain and path. Enter https://aspnetclusters-176858-0.cloudclusters.net/my/ in browser.

4.2 Using your domain to access the asp.net core 8.0 project.

If you have your own domain, then you can use your domain name to access your asp.net core 8.0 project. Add your domain to client panel. Please also update DNS records for your domain and let it pointing to the IP address we provided in client panel.

For example, if we add domain name myasp8.0.tripanels.com to client panel: Then please make a new file like below:

# cd /cloudclusters/config/nginx
# cp default.conf myproject.conf
# vim myproject.conf

Example for myproject.conf

server {
    listen 80;
    server_name myasp8.0.tripanels.com;

    location / {
        proxy_pass http://127.0.0.1:5300$request_uri;
        root /cloudclusters/myproject;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_buffering off;
    }
}

Restart nginx:

Use the domain to access the asp.net core 8.0 project. Enter URL: http://myasp8.0.tripanels.com in browser.

Copyright © 2021 Cloud Clusters Inc. all right reserved,powered by GitbookRevised on 01/04/2025

results matching ""

    No results matching ""